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AN ACTIVE DATA TYPE VARIABLE FOR USE IN SOFTWARE ROUTINES 
THAT FACILITATES CUSTOMIZATION OF SOFTWARE ROUTINES AND 
EFFICIENT TRIGGERING OF VARIABLE PROCESSING 



5 TECHNICAL FIELD OF THE INVENTION 

The present invention relates to an active data type and, more particularly, to 
an active data type used as a variable in a computer program that enables software 
routines to be augmented by providing a systematic technique for adding algorithmic 
processing to the data passed to or retrieved from those routines. In general, the 

iO present invention enables stand-alone, active data type variables to be defined as 

having values that are algorithmically calculated or determined when those variables 
are read and/or set. The active data type variable enables software routines to be 
easily customized and for the customized routines to be reusable. Furthermore, 
processing of the active data type variable is efficiently performed because processing 

1 5 preferably is only triggered when the values associated with the variable are read 
and/or set. 

BACKGROUND OF THE INVENTION 

The desire to make use of existing or new software routines for new 
20 applications is not new. Nearly every programming language, including C++, Visual 
Basic, HP Vee, and Lab View provide capabilities to invoke such routines. The 
routines themselves may be cast in a dynamically linked library form, an Active X 
component form, a Corba component form, or a variety of others. The languages can 
be used to customize or fit the routines to be reused as needed. The customization 
25 cannot be extended across reuse instances of the customized routines. Furthermore, 
these solutions all require a considerable amount of programming skill to use 
effectively, and frequently require that a "wrapper" routine be written in the 
programming language in order to cast the original routine in a new role as a new 
routine ready to reuse. 
30 Test Executive programs, such as, for example, TestStand from National 

Instruments and TestExec SL from Agilent Technologies, are computer programs 
designed to enable users to reuse test and measurement software routines to create test 
programs and manage the testing operation. Test Executives frequently provide 
language-like features that enable customization of the operation of those routines. 
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However, like general purpose programming languages, they do not provide ways to 
systematically customize the operation of those routines across a number of reuse 
instances. To do this requires the same style of "wrapper" routines mentioned above, 
which are usually performed using a general-purpose language, such as those 
5 mentioned above, for example. This type of customization typically must be 

performed outside of the Test Executive development environment, and hence can be 
cumbersome. 

As is generally known in computer programming, sometimes processing must 
be performed whenever the value of a variable changes. In most applications, this is 

1 0 accomplished by periodically checking for a new value in that variable and 

performing whatever processing is required when a new value is detected. This 
technique can be quite inefficient, especially in cases where the value changes 
infrequently and processing must be done quickly after a change is detected. In such 
cases, the value must be checked quite frequently and most checks correspond to 

15 wasted processing. Being able to trigger the processing at the point of change in the 
value of that variable would be more efficient, but doing so is not easily accomplished 
using existing solutions. 

Accordingly, a need exists for an active data type that functions as a variable 
and that enables software routines to be easily customized. Furthermore, a need also 

20 exists for such an active data type that causes processing of the variable to be 
triggered in an efficient manner. 

SUMMARY OF THE INVENTION 

The present invention provides an active data type for use in a computer 
25 program. The active data type has an identifier and at least one algorithm associated 
therewith. The identifier is utilized by the computer program to identify an instance 
of the active data type. The algorithm is configured to be automatically executed 
when an attempt is made to access a value associated with an instance of the active 
data type. The active data type may be a real, an integer, or a string, for example. 
30 When the attempt to access the value associated with the active data type is 

made by a particular routine, the algorithm is automatically executed, which 
preferably determines the current value associated with the active data type instance. 
Preferably, the active data type has an identifier, a first algorithm and a second 
algorithm associated therewith. The first algorithm preferably automatically 
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determines the current value of the instance of the active data type when a routine that 
utilizes the value of the active data type instance attempts to access the value. When 
the value of the instance of the active data type is set, the second algorithm preferably 
automatically post-processes the value to which the active data type instance has been 
5 set. 

Preferably, a locking/unlocking mechanism is provided that locks the value of 
the active data type instance prior to invoking the particular routine and unlocks the 
value of the active data type instance once the routine has returned in order to allow a 
new value of the active data type instance to be set. By locking the value of the active 

10 data type instance when the routine is invoked and by unlocking the value when the 
routine returns, intermediate values generated by the routine are not set. Only the 
final value generated by the routine is set once the routine returns. 

The present invention also relates to an apparatus for executing a computer 
program utilizing the active data type and to a method for utilizing the active data 

1 5 type in a computer program. These and other aspects and features of the present 

invention will become apparent from the following description, drawings and claims. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram demonstrating the manner in which the present 
20 invention may be implemented in a Test Executive environment where test routines 
are utilized in conjunction with a Test Executive program to test various types of 
instruments. 

Fig. 2 is a block diagram demonstrating the manner in which the active data 
type of the present invention may be used in conjunction with format strings. 
25 Fig. 3 is a block diagram demonstrating the manner in which the active data 

type of the present invention may be used in conjunction with a string format wherein 
the values of symbols and parameters used in the string format may be set based upon 
a new string value extracted from a string format. 

Fig. 4 is a state diagram demonstrating string formatting locking in accordance 
30 with one embodiment of the present invention. 

Fig. 5 A is a block diagram demonstrating the manner in which an arbitrary 
algorithm associated with a symbol may be executed to determine the value of a 
symbol whenever that value is requested by some other routine. 
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Fig. 5B is a block diagram demonstrating the manner in which an arbitrary 
algorithm associated with a symbol automatically processes the value of the symbol 
when some other routine attempts to set the value of the symbol. 



5 DETAILED DESCRIPTION OF THE INVENTION 

As will be seen from the following discussion, the active data type of the 
present invention enables the behavior of existing software routines to be customized 
in such a manner that the customized routine itself is capable of being reused, and the 
customization is extendable across instances of the customized routine. The active 

1 0 data type enables variable values to be algorithmically defined such that users of a 
particular active data type variable need not be aware of or concerned about the 
algorithm being invoked. This algorithmic definition is generated with the latest 
possible binding of the variable value, in that the value is calculated at the point of 
access. The present invention also enables algorithmic post-processing of the value of 

15 a variable to be triggered by variable value changes. This represents the earliest 
possible binding for post-processing the value as it is set. In addition, the present 
invention enables a parameterized general algorithm to be associated with the active 
data type for algorithmic processing of the active data type. All of these features of 
the present invention provide a technique for controlling how often the algorithmic 

20 processing associated with an active data type variable is performed. 

The active data type variable of the present invention is useful for 
implementation with various types of the aforementioned Test Executive programs. 
Such Test Executive programs are typically used by customers who have a body of 
existing test and measurement routines that they wish to make use of within the Test 

25 Executive environment. Other data-intensive environments, such as databases and 
spreadsheets, for example, may be other good application areas for the present 
invention. Those skilled in the art will understand, in light of this disclosure, that the 
present invention is not limited to these practical applications. Those skilled in the art 
will understand that the present invention will have significant practical uses in 

30 virtually an infinite number of computer-related environments, either currently known 
or developed in the future. However, for purposes of illustration, the present 
invention will be discussed with reference to its use in a Test Executive environment 
for testing instruments and obtaining test measurement data. 
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Fig. 1 demonstrates a Test Executive environment in which the active data 
type variable of the present invention may be utilized with test routines in order to test 
instruments. A computer 10 executes a Test Executive program 1 1 . The Test 
Executive program 1 1 performs various test routines 13 that are used to control 
5 various types of instruments, which are collectively referred to by block 14. The 
computer 10 is in communication with the data store 15 to enable the computer 10 to 
retrieve data from and store data in data store 15 associated with the execution of the 
Test Executive program 1 1 and the various test routines 13. Those skilled in the art 
will understand that the data store might be a database, a collection of files, or other 

10 forms of data repositories. The manner in which the test environment illustrated in 
Fig. 1 can be implemented is known to those skilled in the art. The following 
discussion describes the active data type variable of the present invention and the 
manner in which it can be utilized in the Test Executive environment shown in Fig. 1 . 
As stated above, in accordance with the present invention, the test routines 13 

1 5 can be customized utilizing the active data type techniques of the present invention 
and the customized test routines, and instances thereof, can be reused. The test 
routines 13 preferably are stored in the data store 15 and envoked by the Test 
Executive program 1 1 when the computer 10 receives instructions from a user via the 
console of the computer 10. Therefore, the active datatype variables themselves and 

20 the test routines in which they are utilized are stored on some type of computer- 
readable storage device. Of course, the present invention is not limited with respect to 
the type of computer-readable storage device that is utilized for this purpose. Those 
skilled in the art will understand that a suitable storage device for such a purpose may 
be, for example, a magnetic storage medium, an optical storage medium, a solid state 

25 storage medium, or any other type of storage medium known now or developed in the 
future. The computer 10 comprises hardware or hardware and software for 
performing the associated tasks. These tasks include execution of the test executive 
program 11, execution of one or more test routines 13, customization of one or more 
of the test routines 13 in accordance with user input via the console of the computer 

30 10, accessing the data store 15 and sending/receiving messages to and from the 
instruments 14 being tested. 

One specific useful application of the active data type variable is its use in 
supporting string formatting (i.e., both string value setting and string value parsing), 
as well as its use in arithmetic expressions to identify real numbers and integers. 
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Other practical applications of the active data type variable relate to its ability to be 
configured to algorithmically select the correct calibration values to be used in a test 
measurement software routine based on parameters such as, for example, temperature, 
time, etc. For example, assuming processing of the active data type variable is 
5 triggered upon reading the value of the variable, the temperature parameter value 
being used in the routine may be algorithmically processed to determine or select 
calibration values for the routine. 

Generally, the use of the active data types variables of the present invention 
would provide a generic method that would enable users to control message-based 

10 instruments without resorting to traditional programming. By using the active data 
type variable, users will be able to create routines {e.g., measurement routines) that 
are functionally analogous to routines developed using a general purpose 
programming language. Moreover, the user will be able to easily generate the 
measurement routines themselves without having to utilize a general purpose 

15 programming language. As stated above, generating such routines by utilizing a 
general purpose programming language typically requires that the user write a 
wrapper routine, which can be tedious. Furthermore, the user would be required to 
know the particular programming language in order to write the wrapper routine. 
The active data type variable of the present invention provides several 

20 desirable features. By causing processing of the active data type variable to occur 

when the variable is read, or accessed, the binding of algorithmically-defined variable 
values can be postponed until they are needed. This, in turn, enables the frequency 
with which the algorithmic processing is performed to be controlled to avoid 
unnecessary or undesired processing. Likewise, by causing post-processing of 

25 variable values to occur when the values change, the frequency with which the post- 
processing is performed can be controlled to avoid unnecessary or undesired 
processing. 

Utilizing the active data type variable {i.e., a variable with parameters/ 
properties that are active), enables existing software routines to be easily customized 
30 without having to resort to traditional programming. These customized versions of 
the software routines can be reused like (and generally will look like) any other 
routine. Furthermore, universal extensibility of routines independent of the 
implementation or language used for that routine can also be realized. Behavior 
extensions preferably are stored and managed with the data associated with the 
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routine without the knowledge or cooperation of the routine being extended. In 
addition, the triggering of variable processing in accordance with the preferred 
embodiment of the present invention result in performance advantages in routines that 
have variables that are seldom accessed. 
5 A description of the construction and operation of the active data type of the 

present invention will now be provided. Active data types in accordance with the 
preferred embodiment of the present invention are comprised of the following 
components: 

(1) Zero or more extended properties stored with each active data type instance in 
10 order to control the active data type algorithms; 

(2) A data type editor that knows about the active nature of the data type and exposes 
the extended properties for user control; 

(3) The algorithms associated with the data type instance "get" and "set" operations; 
and 

15 (4) A general data type management infrastructure to invoke the data editor, save and 
restore data type instances with associated extended properties, prepare the execution 
environment for active data type algorithmic processing, control access to the data 
instance, and invoke the algorithms on data access. 

It can be seen from this description of the active data type of the present 

20 invention that active data type variables can be defined based on an arithmetic 
expression involving other Test Executive user and system variables. These 
expressions preferably are invoked when the variable values are retrieved, and hence 
can provide the most up-to-date value for the expression. In contrast, expressions in 
general purpose programming languages are typically invoked once, namely, when 

25 the value of the variable is set. If the values of the variables in those expressions 
change, the changes are not reflected until the expression is explicitly re-executed. 

In addition, active data type string formatting can be performed in accordance 
with the present invention to enable arbitrary parameters within the Test Executive 
environment to be incorporated into the message (strings) sent to instruments to 

30 control them. In the Test Executive program developed by Agilent Technologies 

Company, known as TestExecSL, these messages are sent to instruments by generic 
message-send and message-receive routines supplied with TestExecSL program. In 
accordance with the present invention, string data types used in such an environment 
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can be made active by providing formatting control. The formatting control feature is 
defined by the following fundamental extended properties: 
(1) Format: a string specifying the format of the string data type instance (e.g., a 
reference to "Variable 1" maybe specified as "%Varl%"); and 
5 (2) Format operation: the type of formatting operation associated with the string data 
type instance. For example, the format operation "Set String" may indicate the format 
to be used to calculate the value of the string. Similarly, the format operation "Scan 
String" may indicate the format to be used to extract sub values from the value to 
which the string is set. 

10 The underlying algorithms of the active data type variable preferably operate 

in a manner very similar to the manner in which the "sprintf ' and the "sscanf" 
functions in the C programming language operate. However, the invocation of these 
functions is controlled in accordance with the aforementioned active data type 
components on access to the data instance rather than by explicit function calls. The 

15 "Set String" formatting operation occurs when any routine reads the value of the data 
type instance. The "Scan String" formatting operation occurs when any routines 
change the value of the data type instance. As stated above, the components of the 
active data type, such as the formatting algorithms and string data editor, enable the 
users of Test Executive program to control the value of the string using a set-string 

20 format or extract subvalues from the string using a scan-string format. 

The following discussion of Fig. 2 provides details on active data type 
implementation in the aforementioned TestExec SL program. The TestExec SL 
program provides support for the use of named symbols and parameters of a variety of 
types, including string data type. For the string data type, the TestExecSL program 

25 supports associating a string format with any instance of a string in a manufacturing 
test program. This string format can either algorithmically specify the value of the 
string or specify how to extract portions of a changed value of the string to set the 
values of other symbols or parameters defined in the manufacturing test program. A 
string format can specify how to construct the value for a string from other symbols or 

30 parameters. A string format in accordance with the present invention may 

conceptually look like the string format shown in Fig. 2. In this case, the parameter 
has a name "Parml" and a value of 5. The % signs are used to delimit the parameter 
name in the string format. For simplicity, Fig. 2 does not illustrate the algorithm 
associated with "Parml" for generating the value associated therewith. 
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Fig. 3 demonstrates the manner in which the values of Symbols and 
Parameters may be set from a New String Value. A string format can specify how to 
extract values from portions of a new string value in order to set the values of other 
symbols or parameters. Therefore, when a message is returned from a test instrument, 
5 it can be parsed and symbols and/or parameters used elsewhere in the test program 
can be set in accordance with the values obtained during the parsing procedure. The 
new string format may then constitute a new message to be sent to the same or a 
different test instrument within the same or a different test routine, respectively. In 
the example shown in Fig. 3, the parameter "Parml" is set equal to the value extracted 

1 0 from the new string value. 

Another aspect of the present invention relates to locking and unlocking of 
string formatting during invocations of routines associated with the active data types. 
This aspect of the present invention will now be discussed with reference to the state 
diagram shown in Fig. 4. If a particular string parameter is accessed frequently, 

15 performing string formatting each time the string is accessed may be too slow for the 
particular routine being performed. It also may be disruptive for an existing routine to 
have the string value change dynamically while that routine runs. For both of these 
reasons, the Test Executive program of the present invention calculates the string 
value before executing a particular routine, then locks that value for the duration of 

20 that routine's execution (i.e., for that instance of the routine), regardless of the number 
of times the string value is retrieved. For the case where new string values set the 
values of other symbols or parameters, string value changes occurring during the 
execution of an existing routine are ignored. After that routine completes, 
TestExecSL 'unlocks' the formatting, allowing the ending string value to determine 

25 the values of any symbols or parameters referenced by the format. 

This behavior is demonstrated by the state diagram of Fig. 4. In accordance 
with this diagram, the state of the string data instance starts at the 'Unbound' state 
(not shown), progresses to the 'Bound' state 21 as its location in memory is fixed, 
proceeds to the 'Action Bound' state 23 when a routine (user routine) is associated 

30 with it, and, finally, proceeds to the 'Action Locked' state 25 when the string value is 
fixed based on the string format, if any. The reverse state progression occurs when 
the Action returns control to the Test Executive (e.g., TestExecSL). In transitioning 
to the 'Action Bound' state 23 from the 'Action Locked' state 25, the string value is 
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used to calculate the values of other parameters and symbols if there is a string format 
and if the correct 'Scan String' format operation has been requested. 

While the TestExecSL implementation of the present invention makes use of 
active data types for string formatting only, the active data type of the present 
5 invention has more general usability, as will be understood by those skilled in the art. 
An arbitrary algorithm could be executed to determine the value of a symbol 
whenever that value is requested by other software. Similarly, an arbitrary algorithm 
could be executed to make use of a new value whenever the value of a symbol is set. 
Fig. 5 A demonstrates the former general implementation of the present invention 

10 whereas Fig. 5B demonstrates the later. As shown in Fig. 5 A, when a user routine 31 
attempts to obtain the value of symbol "A", an arbitrary value processing algorithm 
33 associated with the symbol "A" 32 is automatically executed to determine the 
value of the symbol. The value of the symbol is then sent to the user routine 3 1 . As 
shown in Fig. 5B, when the user routine 31 sets the value of the symbol "A", an 

15 arbitrary value processing algorithm 35 associated with the symbol "A" processes the 
value to make use of the new value. The active data type in this case is symbol "A" 
and has all of the aforementioned attributes of the active data type of the present 
invention. 

The present invention has been described with reference to particular 
20 embodiments, namely, with respect to its implementation in a Test Executive program 
environment. However, as stated above, the present invention is not limited to this 
particular implementation. Those skilled in the art will understand that many 
variations may be made to the embodiments and implementations mentioned above 
without deviating from the spirit and scope of the present invention. 
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CLAIMS 

What is claimed is: 

1 . An active data type for use in a computer program, the active data type being 
5 embodied in a computer-readable medium, the active data type comprising: 

an identifier identifying an instance of the active data type, the computer 
program with which the active data type is utilized identifying the active data type 
instance by the identifier associated with the active data type instance; and 

at least a first algorithm associated with the active data type, the first algorithm 
10 being configured to be automatically executed when an attempt is made to access a 
value associated with the active data type instance. 

2. The active data type of claim 1, wherein the attempt to access the value 
associated with the active data type instance is made by a particular routine, the 

15 algorithm automatically determining the value associated with the active data type 
instance before the routine accesses the value. 

3 . The active data type of claim 2, wherein processing by the algorithm is 
suspended until the particular routine is finished running. 

20 

4. The active data type of claim 3, further comprising: 

a second algorithm associated with the active data type, the second algorithm 
being configured to be automatically executed once the value associated with the 
active data type instance has been set, the second algorithm processing the set value to 
25 generate value processing results. 

5. The active data type of claim 4, wherein the setting of the value and the 
processing of the value by the second algorithm is delayed until the particular routine 
returns, wherein once the particular routine returns, the second algorithm processes 

30 the set value to generate value processing results. 

6. The active data type of claim 1 , wherein the active data type is a parameter 
being utilized by the computer program. 



11 



HPDkt. No. 10991746 



7. The active data type of claim 1 , wherein the active data type is a symbol being 
utilized by the computer program. 

8. The active data type of claim 1, wherein the active data type is a string format 
5 being utilized by the computer program, the string format specifying a format of a 

string data type instance associated with the string format, the string format including 
a format operation, the format operation specifying an operation associated with the 
string data type instance. 

10 9. The active data type of claim 2, wherein the particular routine is a test routine 
utilized for testing a device and obtaining measurement results relating to one or more 
tests performed in testing the device, the test routine being invoked by said computer 
program, said computer program being a Test Executive computer program being 
implemented in a Test Executive program environment. 

15 

10. An apparatus for executing a computer program, the apparatus comprising: 
first logic configured to execute the computer program and any routines 

invoked by the computer program, the computer program utilizing at least one active 
data type, the active data type having an identifier and at least a first algorithm 
20 associated therewith, the identifier identifying an instance of the active data type, the 
first algorithm being automatically executed when an attempt is made to access a 
value associated with the active data type instance. 

1 1 . The apparatus of claim 1 0, wherein the attempt to access the value associated 
25 with the active data type instance is made by a particular routine, and wherein the first 

algorithm automatically determines the value associated with the active data type 
instance before the particular routine accesses the value. 

12. The apparatus of claim 11, wherein once the algorithm has determined the 
30 value of the active data type instance, processing by the algorithm is suspended until 

the routine is finished running. 



12 



HP Dkt. No. 10991746 



13. The apparatus of claim 12, wherein the active data type further has a second 
algorithm associated therewith, the second algorithm configured to be automatically 
executed once the value associated with the active data type instance has been set, the 
second algorithm processing the set value to generate value processing results. 

5 

14. The apparatus of claim 13, wherein the setting of the value and the processing 
of the set value by the second algorithm is delayed until the particular routine returns, 
and wherein once the particular routine returns, the second algorithm processes the set 
value to generate value processing results. 

10 

15. The apparatus of claim 10, wherein the particular routine is a test routine 
utilized for testing a device and obtaining measurement results relating to one or more 
tests performed in testing the device, the test routine being invoked by said computer 
program, said computer program being a Test Executive computer program being 

1 5 implemented in a Test Executive program environment. 

16. A method for utilizing an active data type in a computer program, the active 
data type comprising the steps of: 

identifying an instance of the active data type with an identifier, the active data 
20 type instance being identified by the computer program with which the active data 
type is utilized; and 

automatically executing a first algorithm when an attempt is made to access a 
value associated with the active data type instance. 

25 17. The method of claim 1 6, wherein when the first algorithm is executed, the first 
algorithm automatically determines the value associated with the active data type 
instance. 

18. The method of claim 17, wherein the attempt to access the value of the active 
30 data type instance is made by a particular routine, and wherein once the first 

algorithm has determined the value of the active data type instance, processing by the 
first algorithm is suspended until the particular routine is finished running. 
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1 9. The method of claim 1 8, further comprising the step of: 
automatically executing a second algorithm associated with the active data 

type when a value associated with the active data type instance is set, the second 
algorithm processing the set value to generate value processing results. 

20. The method of claim 19, wherein processing by the second algorithm of the 
set value associated with the active data type is delayed until the particular routine 
returns. 
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ABSTRACT OF THE DISCLOSURE 

The present invention provides an active data type for use in a computer 
program. The active data type has an identifier and at least one algorithm associated 
therewith. The identifier is utilized by the computer program to identify the instance 
of the active data type. The algorithm is configured to be automatically executed 
when an attempt to access a value associated with the active data type instance is 
made by a routine or otherwise. When a particular routine that uses an instance of the 
active data type attempts to access the value associated with the active data type, the 
algorithm determines the value associated with the active data type before the routine 
obtains access to the value. The active data type may be a real, an integer, or a string, 
for example. The algorithm automatically determines the current value associated 
with the active data type instance. Preferably, the active data type has an identifier, a 
first algorithm and a second algorithm associated therewith. The first algorithm 
preferably automatically determines the current value of the instance of the active data 
type when a routine that utilizes the value of the active data type instance attempts to 
access the value. When the value of the instance of the active data type is set, the 
second algorithm preferably automatically post-processes the value to which the 
active data type instance has been set. A locking/unlocking mechanism sets the value 
of the active data type instance prior to the first algorithm invoking the particular 
routine, suspends active data type algorithm processing while the routine executes, 
and processes the value of the active data type instance using the second algorithm 
once the routine has returned in order to post-process any changes to the value of the 
active data type instance. 
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FOR PATENT APPLICATION 



ATTORNEY DOCKET NO. 1Q991 746-1 



As a below named inventor, I hereby declare that: 

My residence/post office address and citizenship are as stated below next to my name; 
I believe I am the original, first and sole inventor (if only one name is listed below) or an original, first and 
joint inventor {if plural names are listed below) of the subject matter which is claimed and for which a 
patent is sought on the invention entitled: 

An Active Data Type Variable For Use In Software Routines That Facilitates Customization Of Software 
Routines And btticient l nggering ut variable Processing 

the specification of which is attached hereto unless the following box is checked: 

( ) was filed on as US Application Serial No. or PCT International Application 

Number and was amended on (if applicable). 

I hereby state that I have reviewed and understood the contents of the above-identified specification, 
including the claims, as amended by any amendment(s) referred to above. I acknowledge the duty to 
disclose all information which is material to patentability as defined in 37 CFR 1.56. 

Foeeign Application(s) and/or Claim of Foreign Priority 

I hereby claim foreign priority benefits under Title 35, United States Code Section 119 of any foreign applii 
inventor(s) certificate listed below and have also identified below any foreign application for patent or invent! 
a filing date before that of the application on which priority is claimed: 



:ation(s) for patent or 
>r(s) certificate having 



COUNTRY 


APPLICATION NUMBER 


DATE FILED 


PRIORITY CLAIMED UNDER 35 U.S.C. 119 


N/A 
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YES: NO: 



Provisional Application 

l hereby claim the benefit under Title 35, United States Code Section 119(e) of any United States provisional application(s) li 
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U. S. Priority Claim 

I hereby claim the benefit under Title 35, United States Code, Section 120 of any United States application(s) listed below and, 
insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States application in the 
manner provided by the first paragraph of Title 35, United States Code Section 112, I acknowledge the duty to disclose material 
information as defined in Title 37, Code of Federal Regulations, Section 1.56(a) which occurred between the filing date of the prior 
application and the national or PCT international filing date of this application: 



APPLICATION SERIAL NUMBER 


FILING DATE 


STATUS (patented/pending/abandoned) 


N/A 



















POWER OF ATTORNEY: 

As a named inventor, I hereby appoint the following attorney(s) and/or 
business in the Patent and Trademark Office connected therewith: 



) prosecute this application and transact all 



Customer Number 022878 



Place Customer 
Number Bar Code 
Label here 



Send Correspondence to: 
AGILENT TECHNOLOGIES 
Legal Department, 51UPD 
Intellectual Property Administration 
P.O. Box 58043 

Santa Clara, California 95052-8043 



Direct Telephone Calls To: 
Cynthia S. Mitchell 
(970) 679-3136 



I hereby declare that all statements made herein of my own knowledge are true and that all statements 
made on information and belief are believed to be true; and further that these statements were made 
with the knowledge that willful false statements and the like so made are punishable by fine or 
imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful 
false statements may jeopardize the validity of the application or any patent issued thereon. 



.Full Name of Inventor: Darvin Dale Raph 



Citizenship: US 



Residence: 
Post Office Address: 



886 S. Edinburgh Drive, Loveland, CO 80537 



Lojfejand, CO 80539 
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Full Name of # 2 joint inventor: Thomas Robert Fay 
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Post Office Address: 
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P.O. Box 301 Loveland, CO 80539 
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